Redis Pub/Sub (Publish/Subscribe)

Database Tutorials - রেডিস (Redis)
237

রেডিস Pub/Sub (Publish/Subscribe) একটি মেসেজ ব্রোকার সিস্টেম যা রেডিসে বার্তা পাঠানো এবং গ্রহণ করার জন্য ব্যবহৃত হয়। এটি একটি পাবলিশার এবং সাবস্ক্রাইবার মডেল অনুসরণ করে। এক বা একাধিক ক্লায়েন্ট একটি নির্দিষ্ট চ্যানেলে মেসেজ পাঠাতে পারে (পাবলিশ), এবং অন্য ক্লায়েন্টরা সেই চ্যানেলে সাবস্ক্রাইব করে মেসেজ গ্রহণ করতে পারে।

Pub/Sub মডেল:

  1. পাবলিশার (Publisher): এটি একটি নির্দিষ্ট চ্যানেলে মেসেজ পাঠায়। এক বা একাধিক পাবলিশার একই চ্যানেলে বার্তা পাঠাতে পারে।
  2. সাবস্ক্রাইবার (Subscriber): এটি একটি বা একাধিক চ্যানেলে সাবস্ক্রাইব করে এবং ঐ চ্যানেলে পাঠানো মেসেজ গ্রহণ করে।
  3. চ্যানেল (Channel): এটি একটি নামকরণ করা "লগ" যেখানে মেসেজ পাঠানো এবং গ্রহণ করা হয়। এটি একটি নির্দিষ্ট প্রকারের ডেটা ফিল্টারিং করতে সহায়ক।

Pub/Sub ব্যবহারের মৌলিক কমান্ড

রেডিসের Pub/Sub মডেল ব্যবহারের জন্য মূলত ৩টি কমান্ড ব্যবহৃত হয়: PUBLISH, SUBSCRIBE, এবং UNSUBSCRIBE


১. PUBLISH কমান্ড

পাবলিশার চ্যানেলে একটি মেসেজ পাঠাতে PUBLISH কমান্ড ব্যবহার করা হয়।

উদাহরণ:

PUBLISH mychannel "Hello, this is a message!"

এটি mychannel চ্যানেলে "Hello, this is a message!" মেসেজটি পাঠাবে।


২. SUBSCRIBE কমান্ড

সাবস্ক্রাইবার একটি নির্দিষ্ট চ্যানেলে সাবস্ক্রাইব করতে SUBSCRIBE কমান্ড ব্যবহার করে।

উদাহরণ:

SUBSCRIBE mychannel

এটি mychannel চ্যানেলে সাবস্ক্রাইব করবে এবং সেখানে আসা মেসেজগুলো গ্রহণ করবে। যদি PUBLISH কমান্ডের মাধ্যমে মেসেজ পাঠানো হয়, সাবস্ক্রাইবার তা রিটার্ন করবে।


৩. UNSUBSCRIBE কমান্ড

সাবস্ক্রাইবার একটি চ্যানেল থেকে সাবস্ক্রিপশন বাতিল করতে UNSUBSCRIBE কমান্ড ব্যবহার করে।

উদাহরণ:

UNSUBSCRIBE mychannel

এটি mychannel চ্যানেল থেকে সাবস্ক্রাইব বাতিল করবে।


Pub/Sub ব্যবহার উদাহরণ

  1. পাবলিশার (Publisher): একটি চ্যানেলে মেসেজ পাঠাচ্ছে।

    PUBLISH news "Breaking news: Redis Pub/Sub in action!"
    
  2. সাবস্ক্রাইবার (Subscriber): চ্যানেলটি সাবস্ক্রাইব করছে।

    SUBSCRIBE news
    

    সাবস্ক্রাইবার news চ্যানেলে মেসেজ পাবেন:

    1) "news"
    2) "Breaking news: Redis Pub/Sub in action!"
    
  3. আরেকটি পাবলিশার (Another Publisher): একই চ্যানেলে মেসেজ পাঠাচ্ছে।

    PUBLISH news "Another update!"
    

    সাবস্ক্রাইবার তখন এই মেসেজটি পাবে:

    1) "news"
    2) "Another update!"
    

Pub/Sub এর উপকারিতা এবং ব্যবহারের ক্ষেত্র

  • রিয়েল-টাইম মেসেজিং: Pub/Sub মডেল রিয়েল-টাইম মেসেজিং সিস্টেমের জন্য উপযুক্ত, যেমন চ্যাট অ্যাপ্লিকেশন বা ইভেন্ট ভিত্তিক সিস্টেম।
  • ডিকোপলিং: পাবলিশার এবং সাবস্ক্রাইবার একে অপরের সাথে সরাসরি যুক্ত না হয়ে মেসেজ আদান প্রদান করে, যার ফলে সিস্টেমের উপাদানগুলোর মধ্যে ডিকোপলিং তৈরি হয়।
  • একাধিক সাবস্ক্রাইবার: একাধিক সাবস্ক্রাইবার একটি চ্যানেলে একই মেসেজ গ্রহণ করতে পারে, যা একাধিক ক্লায়েন্টে রিয়েল-টাইম ইনফরমেশন ডেলিভারি নিশ্চিত করে।
  • অ্যাসিঙ্ক্রোনাস প্রক্রিয়া: Pub/Sub মডেল অ্যাসিঙ্ক্রোনাসভাবে কাজ করে, যেখানে ক্লায়েন্টরা মেসেজ গ্রহণের জন্য অপেক্ষা করে এবং অন্য ক্লায়েন্টরা স্বাধীনভাবে মেসেজ পাঠাতে পারে।

Pub/Sub এর সীমাবদ্ধতা

  • স্টেটলেস: রেডিস Pub/Sub মডেল স্টেটলেস (stateless) হওয়ায়, সাবস্ক্রাইবার যদি একে একে মেসেজ গ্রহণ করতে না পারে, তবে মেসেজ হারিয়ে যাবে। এটি পুনরুদ্ধারযোগ্য নয়।
  • নির্দিষ্ট চ্যানেলস: রেডিসের Pub/Sub শুধুমাত্র নির্দিষ্ট চ্যানেলগুলির জন্য কাজ করে, তাই চ্যানেল নামকরণের কিছু সীমাবদ্ধতা রয়েছে।

সারাংশ

রেডিসের Pub/Sub (Publish/Subscribe) মডেল হল একটি শক্তিশালী মেসেজ ব্রোকার সিস্টেম যা একাধিক ক্লায়েন্টের মধ্যে মেসেজ পাঠানো এবং গ্রহণ করার জন্য ব্যবহৃত হয়। এটি রিয়েল-টাইম মেসেজিং অ্যাপ্লিকেশন, ইভেন্ট ড্রিভেন সিস্টেম, এবং লাইটওয়েট মেসেজিং সিস্টেমের জন্য খুবই উপযোগী। Pub/Sub মডেল ব্যবহারের জন্য PUBLISH, SUBSCRIBE, এবং UNSUBSCRIBE কমান্ডগুলি ব্যবহৃত হয়।

Content added By

Pub/Sub কী এবং কিভাবে কাজ করে?

318

Pub/Sub (Publish/Subscribe) একটি মেসেজিং প্যাটার্ন যা রেডিসের মতো ডিস্ট্রিবিউটেড সিস্টেমে ব্যবহৃত হয়। এটি রিয়েল-টাইম যোগাযোগ ব্যবস্থা তৈরি করার জন্য ব্যবহৃত হয়, যেখানে এক বা একাধিক পাবলিশার মেসেজ পাঠায় এবং এক বা একাধিক সাবস্ক্রাইবার সেই মেসেজ গ্রহণ করে। রেডিসের Pub/Sub মডেলটি এই প্যাটার্ন বাস্তবায়িত করে, যেখানে মেসেজগুলো চ্যানেল (channel) ভিত্তিক আদান প্রদান করা হয়।

Pub/Sub কী?

Pub/Sub হল একটি মেসেজিং মডেল যেখানে:

  • Publisher (পাবলিশার): এটি মেসেজ পাঠায় একটি নির্দিষ্ট চ্যানেলে।
  • Subscriber (সাবস্ক্রাইবার): এটি চ্যানেলে সাবস্ক্রাইব করে এবং সেই চ্যানেল থেকে মেসেজ গ্রহণ করে।
  • Channel (চ্যানেল): এটি একটি ভার্চুয়াল লাইন বা পথ, যার মাধ্যমে মেসেজগুলি পাঠানো এবং গ্রহণ করা হয়।

এটি এমনভাবে কাজ করে যে, সাবস্ক্রাইবারদের মেসেজ পাঠানোর সময় পাবলিশারদের কোনও প্রকার কেয়ার নেওয়ার প্রয়োজন হয় না এবং পাবলিশাররা জানে না কে বা কতজন সাবস্ক্রাইব করেছে।

Pub/Sub কিভাবে কাজ করে?

রেডিসে Pub/Sub এর মাধ্যমে যোগাযোগ তিনটি প্রধান কাজের মধ্যে বিভক্ত:

  1. Publish (পাবলিশ): পাবলিশার একটি চ্যানেলে মেসেজ পাঠায়। এটি একটি বিশেষ চ্যানেল বা নেমস্পেস হতে পারে, যা নির্দিষ্ট ধরনের মেসেজের জন্য ব্যবহৃত হয়।
  2. Subscribe (সাবস্ক্রাইব): সাবস্ক্রাইবার একটি বা একাধিক চ্যানেলে সাবস্ক্রাইব করে, যার ফলে তারা সেই চ্যানেল থেকে মেসেজ গ্রহণ করতে সক্ষম হয়।
  3. Unsubscribe (আনসাবস্ক্রাইব): সাবস্ক্রাইবার কোনো চ্যানেল থেকে আনসাবস্ক্রাইব করলে, তারা আর সেই চ্যানেল থেকে মেসেজ গ্রহণ করবে না।

Pub/Sub কমান্ড

রেডিসের Pub/Sub সিস্টেমে কিছু গুরুত্বপূর্ণ কমান্ড রয়েছে:


১. SUBSCRIBE কমান্ড

এটি একটি বা একাধিক চ্যানেলে সাবস্ক্রাইব করতে ব্যবহৃত হয়। যখন আপনি কোনো চ্যানেলে সাবস্ক্রাইব করেন, তখন রেডিস ওই চ্যানেলে পাঠানো মেসেজগুলো পাঠাবে।

SUBSCRIBE channel_name   # একটি চ্যানেলে সাবস্ক্রাইব

এখানে channel_name হল আপনার সাবস্ক্রাইব করা চ্যানেলের নাম। সাবস্ক্রাইব করার পর, যদি কোনো পাবলিশার ওই চ্যানেলে মেসেজ পাঠায়, সাবস্ক্রাইবার সেই মেসেজ পাবে।


২. PUBLISH কমান্ড

পাবলিশাররা একটি নির্দিষ্ট চ্যানেলে মেসেজ পাঠানোর জন্য PUBLISH কমান্ড ব্যবহার করে:

PUBLISH channel_name "Your message"   # একটি চ্যানেলে মেসেজ পাঠানো

এই কমান্ডটি চ্যানেলটি নির্ধারণ করে এবং মেসেজটি পাঠায়। সব সাবস্ক্রাইবার যাদের ওই চ্যানেলে সাবস্ক্রিপশন আছে, তারা মেসেজটি পাবে।


৩. UNSUBSCRIBE কমান্ড

আপনি যদি কোনো চ্যানেল থেকে আনসাবস্ক্রাইব করতে চান, তাহলে UNSUBSCRIBE কমান্ড ব্যবহার করবেন:

UNSUBSCRIBE channel_name  # চ্যানেল থেকে আনসাবস্ক্রাইব করা

এটি সাবস্ক্রিপশন বন্ধ করে দেয় এবং ওই চ্যানেল থেকে আর মেসেজ পাবেন না।


Pub/Sub মডেলের সুবিধা

  1. ডিকপ্লিং (Decoupling):
    • পাবলিশার এবং সাবস্ক্রাইবারের মধ্যে কোনো সরাসরি সম্পর্ক নেই। সাবস্ক্রাইবাররা শুধুমাত্র চ্যানেলে মেসেজের জন্য অপেক্ষা করে এবং পাবলিশাররা জানে না যে কে মেসেজ গ্রহণ করবে।
  2. রিয়েল-টাইম মেসেজিং:
    • Pub/Sub মডেলটি রিয়েল-টাইম কমিউনিকেশন সিস্টেম তৈরি করতে সাহায্য করে। একাধিক সাবস্ক্রাইবার একযোগে রিয়েল-টাইম মেসেজ পেতে পারে।
  3. স্কেলেবিলিটি:
    • আপনি নতুন সাবস্ক্রাইবার যুক্ত করতে পারেন এবং পাবলিশারদের জন্য এই প্রক্রিয়া নিরবিচ্ছিন্ন থাকে। অনেক পাবলিশার একাধিক সাবস্ক্রাইবারকে মেসেজ পাঠাতে পারে।
  4. ইনস্ট্যান্ট আপডেট:
    • Pub/Sub ব্যবহার করলে, আপনি সরাসরি সব সাবস্ক্রাইবারকে ইনস্ট্যান্ট আপডেট দিতে পারেন, যা বিশেষ করে লাইভ ফিড, চ্যাট অ্যাপ্লিকেশন এবং নিউজ আপডেটের জন্য উপকারী।

Pub/Sub এর ব্যবহারের কিছু উদাহরণ

  1. চ্যাট অ্যাপ্লিকেশন:
    • একটি চ্যাট অ্যাপ্লিকেশনে বিভিন্ন গ্রুপের জন্য পৃথক চ্যানেল থাকতে পারে, এবং ব্যবহারকারীরা নির্দিষ্ট গ্রুপে সাবস্ক্রাইব করে চ্যাটের মেসেজ পেতে পারে।
  2. লাইভ ফিড বা নোটিফিকেশন:
    • আপনি যদি কোন নিউজ বা ফিড সার্ভিস তৈরি করতে চান, যেখানে সাবস্ক্রাইবাররা তাদের পছন্দসই নিউজ ফিড সাবস্ক্রাইব করতে পারে, তাহলে Pub/Sub ব্যবহার করা হবে। যেমন, নতুন আর্টিকেল প্রকাশ হলে সাবস্ক্রাইবাররা তা সরাসরি পাবে।
  3. রিয়েল-টাইম ডেটা আপডেট:
    • ফাইন্যান্সিয়াল মার্কেট বা গেমিং সিস্টেমে, যেখানে ব্যবহারকারীরা রিয়েল-টাইম ডেটা বা স্কোর আপডেট পেতে চায়, Pub/Sub ব্যবহৃত হয়।

Pub/Sub-এর সীমাবদ্ধতা

  1. Persistent Messaging:
    • Pub/Sub মডেলটি বার্তা স্থায়ী করে রাখে না। অর্থাৎ, যদি কোনো সাবস্ক্রাইবার চ্যানেল থেকে কিছু সময়ের জন্য চলে যায়, তাহলে তারা পাঠানো পূর্ববর্তী মেসেজগুলো মিস করবে। এটি শুধুমাত্র রিয়েল-টাইম মেসেজিং সিস্টেমে কার্যকর।
  2. No Acknowledgment:
    • Pub/Sub মডেলটি মেসেজ প্রেরণের পরে কোনও নিশ্চিতকরণ বা acknowledgment দেয় না। মেসেজ পাঠানো এবং গ্রহন নিশ্চিত হয় না, এবং এটি বিশেষ ক্ষেত্রে একটি সীমাবদ্ধতা হতে পারে।

সারাংশ

Pub/Sub রেডিসের একটি শক্তিশালী মেসেজিং প্যাটার্ন, যা পাবলিশারদের দ্বারা মেসেজ পাঠানো এবং সাবস্ক্রাইবারদের দ্বারা সেই মেসেজ গ্রহণ করার জন্য ব্যবহৃত হয়। এটি রিয়েল-টাইম মেসেজিং, চ্যাট, লাইভ ফিড, এবং ডেটা আপডেট সিস্টেমে ব্যবহৃত হয়। PUBLISH, SUBSCRIBE, এবং UNSUBSCRIBE কমান্ডগুলো ব্যবহার করে আপনি Pub/Sub মডেলটি রেডিসে প্রয়োগ করতে পারেন।

Content added By

Redis Pub/Sub Channels তৈরি করা

233

Redis Pub/Sub (Publish/Subscribe) হল একটি messaging প্যাটার্ন যা রেডিসের মাধ্যমে রিয়েল-টাইম মেসেজিং সিস্টেম তৈরি করতে ব্যবহৃত হয়। Pub/Sub প্যাটার্নে, একটি Publisher মেসেজ প্রকাশ করে এবং এক বা একাধিক Subscriber সেই মেসেজ গ্রহণ করে। Redis Pub/Sub ব্যবহার করে আপনি একটি চ্যানেল তৈরি করতে পারেন যেখানে মেসেজ পাঠানো এবং গ্রহণ করা হয়।


Redis Pub/Sub Channels তৈরি করার ধারণা

Redis Pub/Sub ব্যবহার করতে, একটি বা একাধিক ক্লায়েন্ট Publisher হিসেবে মেসেজ প্রেরণ করবে এবং অন্য ক্লায়েন্ট Subscriber হিসেবে সেই মেসেজ গ্রহণ করবে। চ্যানেলগুলো Redis-এ ডায়নামিকভাবে তৈরি হয়, অর্থাৎ আপনাকে চ্যানেল তৈরি করার জন্য কোনো পূর্বনির্ধারিত কাজ করতে হয় না, এটি সম্পূর্ণরূপে রানটাইমে পরিচালিত হয়।

Redis Pub/Sub-এর মূল কমান্ডগুলো হলো:

  1. PUBLISH - Publisher চ্যানেলে মেসেজ প্রেরণ করে।
  2. SUBSCRIBE - Subscriber চ্যানেলে মেসেজ গ্রহণ করার জন্য সাবস্ক্রাইব করে।
  3. UNSUBSCRIBE - Subscriber চ্যানেল থেকে সাবস্ক্রাইব বাতিল করে।

Redis Pub/Sub Channels তৈরি এবং ব্যবহারের জন্য উদাহরণ

১. Redis CLI-তে Pub/Sub ব্যবহারের জন্য নির্দেশনা

  1. Publisher (PUBLISH)

    • Redis CLI-এ একটি চ্যানেলে মেসেজ পাঠানোর জন্য PUBLISH কমান্ড ব্যবহার করতে হবে।
    • উদাহরণস্বরূপ, আমরা একটি চ্যানেল news তে একটি মেসেজ পাঠাবো:
    PUBLISH news "Breaking news: Redis Pub/Sub in action!"
    
  2. Subscriber (SUBSCRIBE)

    • একটি চ্যানেলে মেসেজ গ্রহণ করার জন্য SUBSCRIBE কমান্ড ব্যবহার করতে হবে।
    • আপনি যদি news চ্যানেলে সাবস্ক্রাইব করতে চান, তবে নিচের কমান্ডটি ব্যবহার করুন:
    SUBSCRIBE news
    
  3. একাধিক চ্যানেলে সাবস্ক্রাইব করা

    • আপনি একাধিক চ্যানেলে সাবস্ক্রাইব করতে পারেন। উদাহরণস্বরূপ:
    SUBSCRIBE news sports
    
  4. Unsubscribe (UNSUBSCRIBE)

    • আপনি একটি বা একাধিক চ্যানেল থেকে সাবস্ক্রাইব বাতিল করতে UNSUBSCRIBE কমান্ড ব্যবহার করতে পারেন:
    UNSUBSCRIBE news
    

২. Python-এ Redis Pub/Sub ব্যবহার

Redis Pub/Sub ব্যবহারের জন্য Python-এ redis-py লাইব্রেরি ব্যবহার করা হয়। প্রথমে, লাইব্রেরি ইনস্টল করতে হবে:

pip install redis

Publisher কোড (Python)

import redis

# Redis ক্লায়েন্ট তৈরি
r = redis.Redis()

# মেসেজ প্রকাশ (Publish)
channel = 'news'
message = 'Breaking news: Redis Pub/Sub in Python!'
r.publish(channel, message)

print(f"Message '{message}' published to channel {channel}")

Subscriber কোড (Python)

import redis

# Redis ক্লায়েন্ট তৈরি
r = redis.Redis()

# চ্যানেল সাবস্ক্রাইব করা
pubsub = r.pubsub()
pubsub.subscribe('news')

print("Subscribed to 'news' channel")

# মেসেজ গ্রহণ করা
for message in pubsub.listen():
    print(message)
    if message['type'] == 'message':
        print(f"Received message: {message['data']}")
  • Publisher কোডে r.publish(channel, message) কমান্ড ব্যবহার করা হয়েছে যা চ্যানেল news তে মেসেজ পাঠাবে।
  • Subscriber কোডে pubsub.subscribe('news') দিয়ে চ্যানেলে সাবস্ক্রাইব করা হয়েছে এবং pubsub.listen() ব্যবহার করে মেসেজ শুনা হচ্ছে।

৩. Node.js-এ Redis Pub/Sub ব্যবহার

Node.js-এ Redis Pub/Sub ব্যবহারের জন্য ioredis লাইব্রেরি ব্যবহার করা হয়। প্রথমে, এই লাইব্রেরি ইনস্টল করতে হবে:

npm install ioredis

Publisher কোড (Node.js)

const Redis = require('ioredis');
const redis = new Redis();

// মেসেজ প্রকাশ (Publish)
const channel = 'news';
const message = 'Breaking news: Redis Pub/Sub in Node.js!';
redis.publish(channel, message)
  .then(() => {
    console.log(`Message '${message}' published to channel ${channel}`);
  });

Subscriber কোড (Node.js)

const Redis = require('ioredis');
const redis = new Redis();

// চ্যানেল সাবস্ক্রাইব করা
const channel = 'news';
redis.subscribe(channel, (err, count) => {
  if (err) {
    console.error("Subscription failed:", err);
  } else {
    console.log(`Subscribed to ${channel} channel`);
  }
});

// মেসেজ গ্রহণ করা
redis.on('message', (channel, message) => {
  console.log(`Received message: ${message} from channel ${channel}`);
});
  • Publisher কোডে redis.publish(channel, message) কমান্ড ব্যবহার করা হয়েছে যা চ্যানেল news তে মেসেজ পাঠাবে।
  • Subscriber কোডে redis.subscribe(channel) দিয়ে চ্যানেলে সাবস্ক্রাইব করা হয়েছে এবং redis.on('message') দিয়ে মেসেজ গ্রহণ করা হচ্ছে।

৪. Redis Pub/Sub এর সুবিধা

  1. রিয়েল-টাইম মেসেজিং: Pub/Sub প্যাটার্ন রিয়েল-টাইম মেসেজিংয়ের জন্য উপযুক্ত।
  2. ডিসকনফিগারযোগ্য: Redis Pub/Sub ডায়নামিকভাবে চ্যানেল তৈরি করতে পারে, তাই এটি খুবই ফ্লেক্সিবল।
  3. বিভিন্ন ব্যবহার: চ্যাট অ্যাপ্লিকেশন, লাইভ আপডেট, অ্যালার্ট সিস্টেম, ফিড আপডেট, ইত্যাদিতে এটি ব্যবহৃত হতে পারে।
  4. অর্ডার বিহীন: Pub/Sub মেসেজগুলি অর্ডার বিহীনভাবে সাবস্ক্রাইবারদের কাছে পাঠানো হয়।

সারাংশ

Redis Pub/Sub হল একটি শক্তিশালী মেসেজিং প্যাটার্ন যা রেডিস সার্ভারের মাধ্যমে রিয়েল-টাইম মেসেজ আদান প্রদান করতে ব্যবহৃত হয়। আপনি চ্যানেল তৈরি করে এবং মেসেজ প্রকাশ ও গ্রহণ করে বিভিন্ন ধরনের রিয়েল-টাইম অ্যাপ্লিকেশন তৈরি করতে পারেন। Redis Pub/Sub বিভিন্ন প্রোগ্রামিং ভাষায় সমর্থিত এবং এটি খুবই সহজে ব্যবহারযোগ্য।

Content added By

Publish এবং Subscribe Command এর ব্যবহার

242

রেডিস (Redis)-এ Publish/Subscribe (Pub/Sub) মডেল একটি শক্তিশালী মেসেজিং মেকানিজম যা মেসেজ পাঠানো এবং গ্রহণ করার জন্য ব্যবহৃত হয়। এই মডেলটি মূলত দুইটি পক্ষের মধ্যে যোগাযোগ স্থাপন করে: Publisher এবং Subscriber। Publisher মেসেজ পাঠায় এবং Subscriber সেই মেসেজ গ্রহণ করে।

রেডিসের Pub/Sub সিস্টেম ব্যবহার করে আপনি রিয়েল-টাইম অ্যাপ্লিকেশন যেমন চ্যাট সিস্টেম, লাইভ আপডেট, মেসেজিং সার্ভিস এবং অনেক অন্যান্য ক্ষেত্রে মেসেজ ব্রোকার হিসেবে কাজ করতে পারেন।


Publish/Subscribe (Pub/Sub) কমান্ডের ব্যবহার

রেডিস Pub/Sub মডেলটি তিনটি মূল কমান্ডের উপর ভিত্তি করে কাজ করে:

  1. PUBLISH: মেসেজ পাঠানো।
  2. SUBSCRIBE: চ্যানেল সাবস্ক্রাইব করা।
  3. UNSUBSCRIBE: চ্যানেল সাবস্ক্রাইব বন্ধ করা।

১. PUBLISH কমান্ড

PUBLISH কমান্ড ব্যবহার করে একটি চ্যানেলে মেসেজ পাঠানো হয়। এটি Publisher হিসেবে কাজ করে।

সিনট্যাক্স:

PUBLISH <channel> <message>
  • <channel>: চ্যানেলের নাম (যেখানে মেসেজ পাঠানো হবে)।
  • <message>: পাঠানো মেসেজ।

উদাহরণ:

PUBLISH news "Breaking News: Redis now supports Pub/Sub!"

এটি news চ্যানেলে "Breaking News: Redis now supports Pub/Sub!" মেসেজটি পাঠাবে।


২. SUBSCRIBE কমান্ড

SUBSCRIBE কমান্ড ব্যবহার করে একটি চ্যানেল সাবস্ক্রাইব করা হয়। Subscriber এই চ্যানেল থেকে পাঠানো মেসেজ গ্রহণ করবে।

সিনট্যাক্স:

SUBSCRIBE <channel>
  • <channel>: চ্যানেলের নাম যা আপনি সাবস্ক্রাইব করতে চান।

উদাহরণ:

SUBSCRIBE news

এটি news চ্যানেলটি সাবস্ক্রাইব করবে এবং সেই চ্যানেলে কোন মেসেজ পাঠানো হলে তা শোনাবে।

ব্যাখ্যা: যদি আপনি উপরের কমান্ড রান করেন, তবে আপনি মেসেজ পাবেন, যেমন:

+news
"Breaking News: Redis now supports Pub/Sub!"

এখানে, +news চ্যানেলটির নাম এবং "Breaking News: Redis now supports Pub/Sub!" মেসেজটি রিটার্ন হবে।


৩. UNSUBSCRIBE কমান্ড

UNSUBSCRIBE কমান্ড ব্যবহার করে একটি চ্যানেল থেকে সাবস্ক্রিপশন বন্ধ করা যায়।

সিনট্যাক্স:

UNSUBSCRIBE <channel>
  • <channel>: যে চ্যানেল থেকে আপনি সাবস্ক্রাইব বন্ধ করতে চান।

উদাহরণ:

UNSUBSCRIBE news

এটি news চ্যানেল থেকে সাবস্ক্রাইব বন্ধ করবে।


৪. PSUBSCRIBE কমান্ড (Pattern-based Subscribe)

PSUBSCRIBE কমান্ড ব্যবহার করে আপনি Pattern Matching এর মাধ্যমে একাধিক চ্যানেল সাবস্ক্রাইব করতে পারেন। এটি চ্যানেলের নামের প্যাটার্নে মিলে এমন সব চ্যানেলে সাবস্ক্রাইব করবে।

সিনট্যাক্স:

PSUBSCRIBE <pattern>
  • <pattern>: চ্যানেল নামের প্যাটার্ন।

উদাহরণ:

PSUBSCRIBE news*

এটি news, news.sports, news.weather ইত্যাদি সব চ্যানেলগুলোকে সাবস্ক্রাইব করবে যেগুলো news দিয়ে শুরু হয়।


৫. PUNSUBSCRIBE কমান্ড

PUNSUBSCRIBE কমান্ড ব্যবহার করে আপনি Pattern-based সাবস্ক্রিপশন বন্ধ করতে পারেন।

সিনট্যাক্স:

PUNSUBSCRIBE <pattern>

উদাহরণ:

PUNSUBSCRIBE news*

এটি news* প্যাটার্নের সব চ্যানেল থেকে সাবস্ক্রিপশন বন্ধ করবে।


Pub/Sub Workflow

  1. Publisher: মেসেজ পাঠাবে, যেমন:

    PUBLISH sports "Breaking Sports News!"
    
  2. Subscriber: মেসেজ শোনাবে, যেমন:

    SUBSCRIBE sports
    

    এখন, যতবার sports চ্যানেলে কোনো মেসেজ পাঠানো হবে, Subscriber তা পাবেন।

  3. Unsubscribe: সাবস্ক্রিপশন বন্ধ করতে:

    UNSUBSCRIBE sports
    

Pub/Sub এর ব্যবহার ক্ষেত্র

  1. চ্যাট সিস্টেম: একাধিক ব্যবহারকারী একে অপরকে রিয়েল-টাইম মেসেজ পাঠাতে পারে।
  2. লাইভ আপডেট: ওয়েবসাইটে লাইভ স্কোর, শেয়ার মূল্য, বা সংবাদ হালনাগাদ প্রদর্শন।
  3. নোটিফিকেশন সিস্টেম: ব্যবহারকারীকে বিভিন্ন ইভেন্ট বা পরিবর্তন সম্পর্কে অবহিত করা।
  4. ডিস্ট্রিবিউটেড সিস্টেম: একাধিক সার্ভার বা ক্লায়েন্টের মধ্যে ডেটা ভাগ করা এবং সিঙ্ক্রোনাইজ করা।

সারাংশ

  • Publish/Subscribe (Pub/Sub) মডেল একটি মেসেজিং সিস্টেম, যেখানে Publisher মেসেজ পাঠায় এবং Subscriber সেই মেসেজ গ্রহণ করে।
  • রেডিসের Pub/Sub সিস্টেমে প্রধান কমান্ডগুলো হল: PUBLISH, SUBSCRIBE, UNSUBSCRIBE, PSUBSCRIBE, এবং PUNSUBSCRIBE
  • এটি চ্যাট সিস্টেম, লাইভ আপডেট, নোটিফিকেশন সিস্টেম এবং ডিস্ট্রিবিউটেড সিস্টেমের মতো বিভিন্ন রিয়েল-টাইম অ্যাপ্লিকেশন তৈরিতে ব্যবহৃত হয়।
Content added By

Real-time Messaging System এর জন্য Pub/Sub ব্যবহার

217

Real-time Messaging System তৈরি করার জন্য Redis Pub/Sub (Publish/Subscribe) একটি অত্যন্ত কার্যকরী এবং জনপ্রিয় পদ্ধতি। এটি একটি মেসেজিং প্যাটার্ন যেখানে Publisher মেসেজ পাঠায় এবং Subscriber সেই মেসেজ গ্রহণ করে। Pub/Sub একটি অ্যাসিঙ্ক্রোনাস, রিয়েল-টাইম মেসেজিং সিস্টেম তৈরি করতে সহায়তা করে, যা চ্যাট অ্যাপ্লিকেশন, নোটিফিকেশন সিস্টেম, এবং লাইভ আপডেটের জন্য আদর্শ।

Pub/Sub কী?

Publish/Subscribe একটি মেসেজিং প্যাটার্ন যেখানে Publisher একটি চ্যানেলে মেসেজ পাঠায় এবং Subscriber ঐ চ্যানেল থেকে মেসেজ গ্রহণ করে। এই প্যাটার্নে, পাবলিশার এবং সাবস্ক্রাইবাররা একে অপরের সাথে সরাসরি যোগাযোগ করে না, তারা শুধু চ্যানেলগুলির মাধ্যমে যোগাযোগ করে থাকে। Redis এর Pub/Sub সিস্টেম সহজে বাস্তবায়ন করা যায় এবং এটি খুব দ্রুত এবং স্কেলেবল।


Real-time Messaging System তৈরি করার জন্য Pub/Sub ব্যবহারের পদ্ধতি

1. Redis Pub/Sub: Redis CLI থেকে ব্যবহার

Redis এর Pub/Sub ব্যবহারের জন্য আপনি Redis CLI বা Redis ক্লায়েন্ট লাইব্রেরি ব্যবহার করতে পারেন। প্রথমে, আপনি একটি চ্যানেলে Subscribe করবেন এবং পরে Publish কমান্ডের মাধ্যমে চ্যানেলে মেসেজ পাঠাবেন।

Step 1: Subscriber সেট আপ করা

Redis CLI-এ একটি চ্যানেলে subscribe করতে নিচের কমান্ড ব্যবহার করা হয়:

SUBSCRIBE mychannel

এটি একটি চ্যানেলে সাবস্ক্রাইব করবে এবং সেই চ্যানেলে যে কোনও মেসেজ পাওয়া গেলে তা প্রদর্শন করবে।

Step 2: Publisher থেকে মেসেজ পাঠানো

Redis CLI থেকে publish করতে নিম্নলিখিত কমান্ড ব্যবহার করা হয়:

PUBLISH mychannel "Hello, Real-time Messaging!"

এটি mychannel চ্যানেলে একটি মেসেজ পাঠাবে। যদি কেউ ওই চ্যানেলে সাবস্ক্রাইব করে থাকে, তবে তারা এটি দেখতে পাবে।


2. Pub/Sub in a Real-world Application (Node.js Example)

Node.js দিয়ে একটি রিয়েল-টাইম মেসেজিং সিস্টেম তৈরি করতে, আপনি ioredis বা node-redis লাইব্রেরি ব্যবহার করতে পারেন।

Install Redis Client (ioredis)

প্রথমে, আপনাকে ioredis লাইব্রেরিটি ইনস্টল করতে হবে:

npm install ioredis

Publisher Code (Node.js)

const Redis = require('ioredis');
const redis = new Redis();  // Redis সার্ভারের সাথে কানেক্ট

// Publisher: মেসেজ পাঠানো
function publishMessage(channel, message) {
  redis.publish(channel, message, (err, result) => {
    if (err) {
      console.error("Error publishing message:", err);
    } else {
      console.log(`Message sent to ${channel}: ${message}`);
    }
  });
}

// একটি চ্যানেলে মেসেজ পাঠানো
publishMessage("chat-channel", "Hello, this is a real-time message!");

Subscriber Code (Node.js)

const Redis = require('ioredis');
const redis = new Redis();  // Redis সার্ভারের সাথে কানেক্ট

// Subscriber: চ্যানেলে সাবস্ক্রাইব করা
redis.subscribe("chat-channel", (err, count) => {
  if (err) {
    console.error("Error subscribing to channel:", err);
  } else {
    console.log(`Subscribed to ${count} channel(s)`);
  }
});

// চ্যানেলে মেসেজ আসলে তা প্রক্রিয়া করা
redis.on("message", (channel, message) => {
  console.log(`Received message: ${message} from channel: ${channel}`);
});

Explanation:

  1. Publisher Code: এখানে, publishMessage ফাংশন chat-channel চ্যানেলে মেসেজ পাঠায়।
  2. Subscriber Code: redis.subscribe ব্যবহার করে চ্যানেলটি সাবস্ক্রাইব করে এবং যখনই নতুন মেসেজ আসে, তখন message ইভেন্টে redis.on ব্যবহার করা হয়।

এভাবে, Publisher চ্যানেলে মেসেজ পাঠানোর পর, যেসব ক্লায়েন্ট সেই চ্যানেলে সাবস্ক্রাইব করেছে তারা সেই মেসেজ পাবেন। এটি একটি আদর্শ রিয়েল-টাইম মেসেজিং সিস্টেম তৈরি করে।


3. Use Cases of Redis Pub/Sub in Real-time Systems

Pub/Sub সিস্টেমটি বিভিন্ন প্রকার রিয়েল-টাইম অ্যাপ্লিকেশনে ব্যবহৃত হয়। এর কিছু প্রধান ব্যবহার ক্ষেত্র:

  1. Chat Applications:
    • Pub/Sub ব্যবহৃত হতে পারে গ্রুপ চ্যাট, ব্যক্তিগত চ্যাট বা ফোরাম সিস্টেমে। যেখানে একাধিক ইউজার একই চ্যাট চ্যানেলে মেসেজ পাঠানোর সময় তারা তৎক্ষণাৎ মেসেজগুলি দেখতে পাবে।
  2. Real-time Notifications:
    • যখন একটি ব্যবহারকারী নতুন নোটিফিকেশন পায়, তখন সেটি অন্যান্য ব্যবহারকারীদের কাছে দ্রুত পৌঁছে দিতে Pub/Sub ব্যবহার করা হয়।
  3. Live Data Feeds:
    • লিডারবোর্ড, লাইভ স্পোর্টস স্কোর, মার্কেট ডেটা, বা অন্যান্য বাস্তব সময়ের ডেটা আপডেটের জন্য Pub/Sub ব্যবহৃত হয়।
  4. Event-driven Architectures:
    • অ্যাপ্লিকেশন বা সিস্টেমের বিভিন্ন অংশের মধ্যে ইভেন্ট ট্রিগার করার জন্য Pub/Sub সিস্টেম ব্যবহৃত হয়, যেমন, লগিং, ট্রান্সফার কমপ্লিশন ইত্যাদি।
  5. Real-time Collaboration:
    • যেমন গুগল ডক্স বা টুইটার—যেখানে একাধিক ব্যবহারকারী একসাথে ডকুমেন্ট বা কন্টেন্টে কাজ করতে পারে এবং তাদের পরিবর্তন তৎক্ষণাৎ অন্যদের কাছে পৌঁছায়।

4. Scaling Pub/Sub with Redis

Redis-এর Pub/Sub সিস্টেম সহজেই স্কেল করা যায়, তবে যদি অনেক ব্যবহারকারী একযোগে মেসেজ গ্রহণ করতে চান, তখন কিছু কৌশল প্রয়োগ করা দরকার:

4.1. Redis Clustering

Redis Pub/Sub এর মাধ্যমে একটি ক্লাস্টার তৈরি করলে আপনি উচ্চ পরিমাণে মেসেজিং সিস্টেমের স্কেলেবিলিটি বাড়াতে পারেন। Redis ক্লাস্টার অনেকগুলো Redis নোডের সমন্বয়ে কাজ করে এবং মেসেজ পাঠানোর সময় ডেটাকে শার্ড করে।

4.2. Horizontal Scaling

Redis নোডগুলিকে শর্ডিং (sharding) করে এবং একাধিক Redis সার্ভারে Pub/Sub সিস্টেমের লোড ভাগ করে নিতে পারেন। এটি আপনার Pub/Sub সিস্টেমের পারফরম্যান্স এবং রেসপন্স টাইম উন্নত করবে।

4.3. Multi-Channel Support

আপনি একাধিক চ্যানেল ব্যবহার করে Pub/Sub সিস্টেমে লোড ভারসাম্য করতে পারেন। উদাহরণস্বরূপ, একটি চ্যাট অ্যাপ্লিকেশন যেখানে আলাদা আলাদা চ্যাট রুমের জন্য আলাদা চ্যানেল ব্যবহার করা যায়।


সারাংশ

Redis এর Pub/Sub একটি শক্তিশালী এবং স্কেলেবল মেসেজিং সিস্টেম তৈরি করার জন্য অত্যন্ত কার্যকরী। এটি রিয়েল-টাইম মেসেজিং, নোটিফিকেশন এবং ইভেন্ট-ড্রিভেন আর্কিটেকচার তৈরি করতে সাহায্য করে। আপনি Redis CLI বা ক্লায়েন্ট লাইব্রেরি (যেমন Node.js, Python) ব্যবহার করে Pub/Sub সিস্টেম তৈরি করতে পারেন। রিয়েল-টাইম অ্যাপ্লিকেশনগুলির জন্য, Pub/Sub একটি আদর্শ প্যাটার্ন, যা সহজে স্কেল করা যায় এবং কার্যকরী।

Content added By
Promotion
NEW SATT AI এখন আপনাকে সাহায্য করতে পারে।

Are you sure to start over?

Loading...